草庐IT

MongoDb 查询 - 计数 + where 条件

全部标签

ruby - 使用 ActiveRecord 在查询对象中转义参数?

给定一个查询对象(不是AR模型)classComplexQueryQUERY=如何方便地转义所有参数?我成功地使用了三种技术,但没有一种是方便的。使用raw_connection(对我而言)返回PG::Conn的实例并调用exec_params。我对此并不满意,因为exec_params需要一组详细的参数来指定数据类型。在我的查询对象中包含ActiveRecord::Sanitization并使用其中一种方便的方法,例如replace_named_bind_variables。我对此不满意,因为replace_named_bind_variables是protected并且我必须使用s

ruby - 具有动态条件的 rspec `its` 语法

我真的很喜欢将contexts、subjects和its与rspec一起使用来真正清理我的测试代码。典型例子:context"asauser"dosubject{Factory:user}its(:name){should=="Bob"}end但我想不通的是如何使这种情况动态化(即基于其他对象)。its似乎对block内的属性进行实例评估,因此我无法访问它周围的所有内容。我很想做这样的事情:its(:name){should==subject.contact.name}但我看不出有什么方法可以实现这一点。有谁知道是否有一些方法代理到这个实例eval来访问原始对象?或者如果有任何其他方法

ruby - ruby 中的条件链接

有没有一种在Ruby中有条件地链接方法的好方法?我想在功能上做的是ifa&&b&&cmy_object.some_method_because_of_a.some_method_because_of_b.some_method_because_of_celsifa&&b&&!cmy_object.some_method_because_of_a.some_method_because_of_belsifa&&!b&&cmy_object.some_method_because_of_a.some_method_because_of_cetc...因此,根据许多条件,我想确定在方法链中调

sql - 何时使用 ORM(Sequel、Datamapper、AR 等)与纯 SQL 进行查询

我的一位同事目前正在设计如下所示的SQL查询以生成报告,这些报告通过外部数据查询显示在excel文件中。目前只需要DB上的上报流程(无CRUD操作)。我试图说服他最好使用ruby​​ORM以便能够在rails/sinatra应用程序中显示数据。尽管在显示数据方面有明显的优势,但学习使用像Sequel或Datamapper这样的ORM对他有什么优势?他正在编写的SQL查询显然相当复杂,并且对SQL比较陌生,他经常提示它非常耗时且令人困惑。是否可以使用ORM编写极其复​​杂的查询?如果是这样,哪个最合适(我听说Sequel对遗留数据库有好处)?在进行复杂的数据库查询时,学习Ruby和使用O

ruby - 排序:在 Ruby 中根据多个条件对数组进行排序

我有一个像这样的多维数组:[[name,age,date,gender][name,age,date,gender][..]]我想知道根据多个条件对该数组进行排序的最佳方法...例如,我将如何根据年龄先然后按姓名排序?我像这样摆弄sort方法:array.sort{|a,b|[a[1],a[0]][b[1],b[0]]}除此之外我并不真正理解这种语法,我没有得到我期望的结果。我应该使用sort方法吗?我应该通过映射数组来单独比较结果吗? 最佳答案 您应该始终使用sort_by进行键控排序。它不仅更具可读性,而且效率也更高。此外,为了

ruby - 根据某些条件在 ruby​​ 中拆分数组

我有一个名为@level1的数组,它的值如下:[[3.1,4],[3.0,7],[2.1,5],[2.0,6],[1.9,3]]我想把它分成两个数组,第一个数组(@arr1)包含直到2.1的值,第二个数组(@arr2)包含其后的值。这样做之后,我将通过执行以下操作对我的第二个数组进行反向排序:@arr2=@arr2.sort_by{|x,_|x}.reverse然后我想将这个数组合并到@arr1。有人可以帮助我如何拆分数组然后将它们合并在一起吗? 最佳答案 试试partition方法@arr1,@arr2=@level1.parti

ruby-on-rails - Rails/ERB 中的条件标记包装

在ERB中,什么是最可读和/或最简洁的写法?编写我自己的方法并不可取,因为我想为此向我公司的其他人传播一个更清洁的解决方案。==更新==我使用了一个更通用的Gal答案版本,它与标签无关。defconditional_wrapper(condition=true,options={},&block)options[:tag]||=:divifcondition==trueconcatcontent_tag(options[:tag],capture(&block),options.delete_if{|k,v|k==:tag})elseconcatcapture(&block)enden

ruby-on-rails - rails 4 : How to use includes() with where() to retrieve associated objects

我不知道如何使用.where()检索关联模型数据的方法。在此示例中,项目belongs_to用户...classProjectparams[:id]}).firstendend在App/views/projects/invite.html.erg返回:---!ruby/object:Projectattributes:id:22name:SomeProjectNamebelongs_to:1instructions:Blablablaactive:truemax_duration:2max_videos:created_at:2013-08-2615:56:50.000000000Zu

Ruby:条件矩阵?有多个条件的情况?

在ruby​​中,我想知道是否有办法执行以下操作:我基本上有一个包含四种可能结果的矩阵:AisTrue,BisTrueAisTrue,BisFalseAisFalse,BisTrueAisFalse,BisFalse我想用尽可能干净的“ruby方式”为此编写一个测试。我希望做一些类似的事情case[A,B]whenA&&Bthen...whenA&&!Bthen...when!A&&Bthen...when!A&&!Bthen...end...但这不起作用。那么,处理这种情况的最佳方法是什么? 最佳答案 bool案例(在case中没

ruby-on-rails - 在 rails 中过滤 ActiveRecord 查询

我习惯了Django,在那里你可以在查询集上运行多个过滤方法,即Item.all.filter(foo="bar").filter(something="else")。然而,这在Rails中并不容易。Item.find(:all,:conditions=>["foo=:foo",{:foo=bar}])返回一个数组,这意味着这将不起作用:Item.find(:all,:conditions=>["foo=:foo",{:foo='bar'}]).find(:all,:conditions=>["something=:something",{:something='else'}])所以我